, II II •» H i» n n n n i*"n JT H n I 



OO/ST/30 01 -00 



Old '» n it.90C 

IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 

CERTIFICATE OF EXPRESS MAILING Attorney Docket No.: SUN1P376/P4382 

I hereby certify that this paper and the documents and/or fees referred to as 

attached therein are being deposited with the United States Postal Service T7*fTvT Al + Trl H 

on February 15, 2000 in an envelope as "Express Mail Post Office to ^ INamea inventOr: JOraaU iJrOWD^ 

Addressee" service under 37 CFR §1.10, Mailing Label Number H 
EL24391 1764US, addressed to the Assistant Commissioner for Patents, ^ 



Washington, DC 20231. 



Dionna Holmes <X>- — — 

u 
•n 

UTILITY PATENT APPLICATION TRANSMITTAL (37 CFR. § l,53(b)) 

Assistant Commissioner for Patents Q Duplicate for 

Box Patent Application fee processing 

Washington, DC 20231 

jSjr: This is a request for filing a patent application under 37 CFR. § 1 , 53(b) in the name of inventors: 
'% Jordan Brown and Lisa M. Camesano 

jlor: Methods and Apparatus for Managing Debugging I/O 

.Application Elements: 



^ 22 Pages of Specification, Claims and Abstract 
8 Sheets of mformal Drawings 



[ZZl Pages Combined Declaration and Power of Attorney 
Accompanying Application Parts : 

I I Assignment and Assignment Recordation Cover Sheet (recording fee of $40.00 enclosed) 

I I 37 CFR 3.73(b) Statement by Assignee 

I I Information Disclosure Statement with Form PTO-1449 

I I Copies of IDS Citations 
I I Preliminary Amendment 
^1 Return Receipt Postcard 
I I Small Entity Statement(s) 
I I Other: 



(Revised 01/00, Pat App Trans 53(b) Reg Page 1 of 2 



Fee Calculation Cil CFR ^\.16\ 





(Col. 1) (Col. 2) 


SMAT T FTSTTTTV 




T ARGF FNTTTV 




NO. FILED NO. EXTRA 


RATE FEE 




RATE FEE 


BASIC FEE 




$345 $ 


OR 


$690 $690 


TOTAL CLAIMS 


22 -20= 2 


X 9 = $ 


OR 


2x 18 = $36 


INDEP CLAIMS 


5 -03 = 2 


X 39 = $ 


OR 


2x78 = $156 


[ ] Multiple Dependent Claim Presented 


$130 = $ 


OR 


$260 =$ 


* If the difference in Col. 1 is less 


Total $ 


OR 


Total $882 



than zero, enter "0" in Col. 2. 

Please defer filing fees at this time. 

I I Check No. in the amount of $ is enclosed. 



I I The Commissioner is authorized to charge any fees beyond the amount enclosed which may be 
required, or to credit any overpayment, to Deposit Account No, 50-0388 (Order No. ). 



GBieral Authorization for Petition for Extension of Time (31 CFR $1.136) 



Applicants hereby make and generally authorize any Petitions for Extensions of Time as may be 
nbfeded for any subsequent filings. The Commissioner is also authorized to charge any extension fees under 
3WCFR §1.17 as may be needed to Deposit Account No. 50-0388 (Order No. SUN1P376). 



Please send correspondence to the following address: 



Customer Number 022434 

BEYER WEAVER THOMAS & NGUYEN, LLP 
P.O. Box 130 
Mountain View, CA 94042-0130 
Telephone (510) 843-6200 
Fax (510) 843-6203 



22434 



PATENT TRADEHftRK OFFICE 



Date: 




Elise R. Heilbrunn 

Registration No. 42,649 



(Revised 01/00, Pat App Trans 53(b) Reg 



Page 2 of 2 



Attorney Docket No. SUN1P376/P4382 



PATENT APPLICATION 



METHODS AND APPARATUS FOR MANAGING 

DEBUGGING I/O 

By Inventors: 

Jordan Brown 
Lisa M. Camesano 



Assignee: Sun Microsystems, Inc. 

901 San Antonio Road 
Palo Alto, CA 94303 



Entity: Large 



BEYER & WEAVER, LLP 
P.O. Box 61059 
Palo Alto, CA 94306 
Telephone (510) 843-6200 



METHODS AND APPARATUS FOR 
MANAGING DEBUGGING I/O 

Background of the Invention 

5 1 . field of the invention 

The present invention relates generally to computer software. More 
particularly, the present invention relates to methods and apparatus for 
providing a mechanism for managing input and output. 

2, DESCRIPTION OF THE RELATED ART 

The ability to debug a system is important during the development of 
the system as well as to ensure proper maintenance of the system upon 
completion of system development. In order to facilitate the debugging 
process, a variety of debugging tools are available. Typically, a debugging 
tool is loaded prior to testing or prior to running a system. When a system 
error occurs, the software developer or engineer may then access the 
debugging tool to identify and correct the error. 

All system components may require debugging at various instances in 
time. For instance, even services provided by the kemel, the essential center 
of a computer operating system that provides basic services for all other parts 
of the operating system, may require debugging due to system errors. 
Typically, a kernel includes an interrupt handler that handles all requests or 
completed I/O operations that compete for the kernel's services, a scheduler 
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that determines which programs share the kernel's processing time in what 
order, and a supervisor that actually gives use of the computer to each process 
when it is scheduled. A kernel may also include a manager of the operating 
system's address spaces in memory or storage, sharing these among all 
5 components and other users of the kernel's services. 

It is particularly important that the functionality of both input and 
output services be preserved dxaring the debugging of any system such as the 
operating system kernel. As one example, it is often desirable to write the 
contents of memory to a file for subsequent analysis. As another example, it 

10 is imperative that the ability to perform keyboard input be fiiUy preserved in 
order to enter debugging commands. 

Although I/O services are required to debug a system successfully, 
when an error occurs in a system such as the kernel, it is likely that the I/O 
operations handled by the kernel are also non-functional. In view of the 

1 5 above, it would therefore be desirable if a debugging tool independent of the 
system being debugged were developed. Moreover, it would be beneficial if a 
mechanism for ensuring I/O functionality during the debugging process could 
be provided. 



20 
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Summary 



The present invention provides a secondary mechanism for performing 
a system function such as I/O fimctionahty. This is accompUshed through a 
set of primitive functions corresponding to a set of system services. The 

5 primitive functions, although "equivalent" to the set of system services, are 
reduced in functionahty as well as performance, hi this manner, a secondary 
mechanism for performing the set of system services is made available in the 
event of a system error. 

In accordance with one aspect of the invention, the set of system 

1 0 services are in the form of a "stack" in which each layer reUes on the functions 
provided by the layers below it. A primitive function request may be sent 
down to lower layers by layers above them in order to request an "equivalent" 
primitive function. The primitive function may, for instance, use polling 
rather than interrupts. In this manner, the primitive functions eliminate or 

15 reduce reliance on system functions which may be non-functional in the event 
of an error, 

hi accordance with another aspect of the invention, a receiving layer of 
a primitive function request may retum identifying information associated 
with a primitive function for that layer. The upper layer receiving this 
20 identifying information may then store this information for later use. Thus, 
the upper layer has access to information that enables it to communicate with 
lower layers in the event of a system error. More particularly, the upper layer 
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may commimicate with one or more identified primitive functions associated 
with one or more lower layers of the stack. 

Through the sending of primitive function requests and the sending of 
responses to those primitive fimction requests, a parallel stack of primitive 
5 mechanisms to the system services stack may be created. The stack of 

primitive mechanisms may be created for a variety of functions including, but 
not limited to, I/O and debugging functions. The appropriate primitive 
functions may then be called by one or more upper layers in the event of an 
error that would otherwise interfere with the "replaced" functions. 

10 
15 
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Brief Description of the Drawings 

The invention, together with further advantages thereof, may best be 
understood by reference to the following description taken in conjunction with 
the following figures: 
5 FIG. 1 is block diagram illustrating an exemplary stack of services 

supporting a USB keyboard. 

FIG. 2 is a block diagram illustrating an exemplary stack of services 
supporting a PS/2 keyboard, 

FIG. 3 A is a block diagram illustrating one embodiment of the present 
10 invention. 

FIG. 3B is an exemplary block diagram illustrating the use of a 
primitive function request to gather primitive function information associated 
with one or more layers of a system services stack in accordance with one 
embodiment of the invention. 
1 5 FIG. 4 is an exemplary diagram illustrating the result of sending 

primitive function requests and returning primitive function information. 

FIG. 5 is an exemplary block diagram illustrating potential ways in 
which primitive functions may be called. 

FIG. 6 is a process flow diagram illustrating one method of supplying 
20 an altemative primitive means for performing a system function. 

FIG. 7 is a block diagram illustrating a typical, general-purpose 
computer system suitable for implementing the present invention. 

Attorney Docket No. SUNl P376/ERH PATENT 



5 



Detailed Description of the Preferred 
Embodiments 

In the following description, numerous specific details are set forth in 
5 order to provide a thorough understanding of the present invention. It will be 
apparent, however, to one skilled in the art, that the present invention may be 
practiced without some or all of these specific details. In other instances, well 
known process steps have not been described in detail in order not to 
uimecessarily obscure the present invention. 

10 It is particularly important in the debugging process that keyboard 

input be capable of being accepted as well as correctly interpreted. Software 
services supporting a functioning keyboard are often implemented in the form 
of a stack. Upper layers in the stack are supported by functions provided in 
lower layers of the stack. FIG. 1 is block diagram illustrating an exemplary 

15 stack of services supporting a USB keyboard. As shown, a top level 102 
performs terminal emulation so that the keyboard and display form a unit. 
Generic keyboard translation 104 provides generic functionality so that 
various keys (e.g., the letter "A") may be recognized when pressed. A USB 
keyboard handler 106 translates keyboard input from the USB human interface 

20 device protocol to generic button press release events (e.g., third button on the 
keyboard) independent of the underlying hardware. In addition, a human 

Attorney Docket No. SUN1P376/ERH PATENT 



6 



interface device handler 108 and a host controller 110 form the remaining 
layers of the stack. More particularly, the human interface device handler 108 
and the host controller 110 interact with information in the form of bits. 

Similarly, FIG. 2 is a block diagram illustrating an exemplary stack of 
5 services supporting a PS/2 keyboard. As shown, the top level 202 performs 
terminal emulation and the second level 204 performs generic keyboard 
translation, as described above with reference to FIG. 1 . In addition, the 
remaining layers include a PS/2 keyboard handler 206 which translates 
hardware specific (i.e., PS/2) representations of button presses into generic 
10 representations of button presses and an 18042 controller 208 which controls 
the hardware that performs the data transfer. Although the previous examples 
are described with reference to a stack of services supporting a keyboard, the 
present invention is not limited to these examples and may be used with other 
devices and in other contexts. 

15 As described above with reference to FIG. 1 and FIG. 2, services that 

provide I/O functionality such as those provided by a keyboard are often 
structured in the form of a stack. However, in the event of a system failure, 
one or more of the services in the stack may become inoperative. In fact, even 
one non-functional layer in the stack can prevent normal I/O functioning, 

20 In accordance with one embodiment of the invention, a set of primitive 

functions corresponding to a set of system services is established. While the 
system services provide full-featured, high performance system services, the 
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primitive functions are equivalents that need not be high performance or full- 
featured. 

The set of system services may be implemented by a set of software 
components to provide functionality for a variety of devices such as a 
5 keyboard. FIG. 3 A is a block diagram illustrating one embodiment of the 

present invention. The set of services are shown here in the form of a "stack." 
Here, the services include a set of functions. More particularly, a first 
layer/service 302 (function A), a second layer/service 304 (function B), and a 
third layer/service 306 (fimction C) are illustrated, hi addition, a set of 

10 primitive functions is associated with the set of services. As shown, the first 
service 302 has an associated primitive function 308 (A primitive function), 
the second service 304 has an associated primitive function 310 (B primitive 
function), and the third service 306 has an associated primitive function 312 
(C primitive function). More particularly, each of the services 302, 304, and 

15 306 may have a reference variable or pointer that identifies the associated 
primitive function. 

hi the event of a system failure, the system software and hardware may 
be unreliable. Thus, the set of primitive functions 308, 310, and 312 repUcates 
the set of services 302, 304, and 306 with reduced functionality and 

20 performance without relying on this unreliable software and hardware. As one 
example, the set of primitive fimctions does not include interrupts. Rather, the 
set of primitive functions uses polling. For instance, characters may be 
provided to a serial line using polling rather than waiting until the information 
is requested by hardware through the use of an interrupt. Thus, the primitive 
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function may continually check if the serial hne is ready for another character. 
As another example, the set of primitive functions does not include timers. 
Instead, the set of primitive functions includes delay loops. For instance, a 
timer is typically used by a system service to request that it be called at a 
5 particular time. Since the system service may be unreliable in the event of an 
error, a delay loop may be used by an associated primitive function to 
continually check if this particular time has been reached. 

Li accordance with one embodiment, a primitive function request 
mechanism is adapted for returning one or more identifiers (e.g., reference 

10 variables or pointers) associated with one or more of the set of primitive 

functions. More particularly, the identifiers associated with the one or more of 
the set of primitive functions are returned in response to a primitive function 
request. A primitive function request may be sent down to any one of the 
layers in the stack. As one example, a first primitive function request 314 is 

15 sent from the first service 302 to the second service 304. Similarly, a second 
primitive function request 316 is sent from the second service 304 to the third 
service 306. hi other words, the primitive function request is "propagated" 
down the one or more layers of the stack of system services. 

In response to a primitive function request, an identifier of one or more 

20 primitive functions is returned by the receiver (e.g., layer or service) of the 

primitive function request. FIG. 3B is an exemplary block diagram illustrating 
the use of a primitive function request to gather primitive function information 
associated with one or more layers of a system services stack in accordance 
with one embodiment of the invention. The primitive function information 
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may include an identifier (e.g., reference or pointer) of the associated primitive 
function. The primitive function information may also include state 
information data to be provided to the primitive function when the primitive 
function is called. Moreover, the state information may include data that 
5 enables the corresponding service to communicate with another one of the set 
of services. More particularly, the state information may include data that 
enables the corresponding primitive function to identify another one of the set 
of primitive functions with which to communicate. 

As shown in FIG. 3B, first primitive function information 318 

10 associated with the first service 302 identifies a first primitive function 320 

and first state information data 322. As described above, the state information 
data may enable the primitive function to identify another primitive function 
with which to commimicate. Thus, the state information data 322 may further 
include or identify at least a portion of second primitive function information 

15 324 associated with the second service 304. The second primitive function 
information 324 similarly identifies a second primitive function 326 and 
second state information data 328 where this state information data further 
identifies or includes at least a portion of third primitive function information 
330 associated with the third service 306. The third primitive function 

20 information 330 identifies a third primitive function 332 as well as third state 
information data 334. Since the third service 306 is shown to be the bottom 
layer in the stack, the third state information data 334 does not include 
primitive function information for any other layer in the stack. The primitive 
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function information shown and described is illustrative only, and therefore 
alternative embodiments are possible. 

In response to a primitive function request, primitive function 
information associated with the primitive function is returned to the requesting 
5 layer or service. As shown, the second primitive function information 324 is 
returned to the first service 302, Similarly, the third primitive function 
information 330 is returned to the second service 304. The primitive function 
information may then be stored as shown to enable the requesting layer in the 
stack to communicate with the lower layer in the stack. These primitive 

10 functions associated with the returned primitive function information are 
ultimately meant to replace the associated services when the set of services 
(e.g., one or more of the services) are determined to be inoperative. 

FIG. 4 is an exemplary diagram illustrating the result of sending 
primitive function requests and returning primitive function information as 

1 5 discussed in conjunction with FIG. 3B. The sending of primitive function 
requests, returning of primitive function information, and storing of this 
primitive function information as state information data may be performed 
over multiple layers of a system services stack. This process may therefore be 
performed such that a stack of primitive mechanisms 400 parallel to the stack 

20 of system services is assembled, as shown. 

Once a stack of primitive mechanisms such as that illustrated in FIG. 4 
is created, the primitive functions may be called using the information 
effectively stored in the stack. FIG. 5 is an exemplary block diagram 
illustrating potential ways in which primitive functions may be called. A 
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primitive function calling mechanism may be provided for calling one or more 
primitive functions associated with the one or more identifiers returned by the 
primitive function request mechanism. The primitive function calling 
mechanism may be associated with one or more of the set of components. 
5 Thus, multiple levels of the primitive function stack may call primitive 

functions associated with lower levels in the stack. For instance, as shown at 
Hne 502, the first level 302 is shown calling the primitive function associated 
with the second level 304. Similarly, the second level 304 is shown calling 
the primitive function associated with the third level 306, as shown at line 

10 504. Thus, in this example, the first level 302 (associated with function A) 
must call the primitive function associated with the second level 304 
(associated with function B) in order to enable the second level 304 of the 
stack to call the primitive function associated with the third level 306 
(associated with function C). Alternatively, a single level (e.g., top level) of 

15 the stack of primitive mechanisms may call one or more primitive functions, 
as shown at line 506. For instance, as shown at line 506, the first level of the 
primitive function stack (e.g., associated with function A 302) may call the 
primitive function associated with function C 306. 

The present invention may be implemented in a variety of ways. FIG. 

20 6 is a process flow diagram illustrating one method of supplying an alternative 
primitive means for performing a system function. As shown, at block 602 
there is a system start up and a stack such as that illustrated in FIG. 4 
representing a set of services is obtained at block 604. A primitive function 
request is sent to one of the layers of the stack (e.g., the top layer of the stack) 
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at block 606. More particularly, the primitive function request requests a 
primitive function from one of the set of system services. Moreover, the same 
or another primitive function request may be sent from the current level in the 
stack to a lower level in the stack as shown at block 608. This may be 
5 performed recursively, as shown. Upon receipt of the primitive function 
requests, the requested primitive function information is sent from one or 
more lower levels in the stack to one or more upper levels in the stack at block 
610. Thus, although blocks 606 through 610 are shown consecutively, these 
functions may actually be performed in parallel since multiple requests may 

10 simultaneously be received and responded to by multiple levels in the stack. 
In accordance with one embodiment of the invention, the set of 
services and the set of associated primitive functions provide functions for 
debugging. Li addition, the set of services and the set of primitive functions 
provide input and output functionality. For instance, the set of services and 

1 5 the set of primitive functions may provide keyboard functionality to enable 
debugging in the event of a system (e.g., kemel) malfunction. Thus, a 
primitive function identifier associated with a requested primitive function 
may be sent only when the associated system service performs a debugging 
function or, alternatively, an input and/or output fimction. It follows that only 

20 in these instances is the primitive function identifier stored. In this 

embodiment, when a layer is responsible for performing input, output, and/or 
debugging functions, it sends a primitive function request to a lower layer in 
the stack so that the primitive means for performing an eqmvalent function 
may be established. 
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The present invention maybe implemented on any suitable computer 
system. FIG. 7 illustrates a typical, general-purpose computer system 1002 
suitable for implementing the present invention. The computer system may 
take any suitable form. For example, the computer system may be integrated 
5 with a digital television receiver or set top box. 

Computer system 1030 or, more specifically, CPUs 1032, maybe 
arranged to support a virtual machine, as will be appreciated by those skilled 
in the art. The computer system 1002 includes any number of processors 1004 
(also referred to as central processing units, or CPUs) that may be coupled to 

10 memory devices including primary storage device 1006 (typically a read only 
memory, or ROM) and primary storage device 1008 (typically a random 
access memory, or RAM). As is well known in the art, ROM acts to transfer 
data and instructions uni-directionally to the CPUs 1004, while RAM is used 
typically to transfer data and instructions in a bi-directional manner. Both the 

15 primary storage devices 1006, 1008 may include any suitable computer- 
readable media. The CPUs 1004 may generally include any number of 
processors. 

A secondary storage medium 1010, which is typically a mass memory 
device, may also be coupled bi-directionally to CPUs 1004 and provides 
20 additional data storage capacity. The mass memory device 1010 is a 

computer-readable medium that may be used to store programs including 
computer code, data, and the like. Typically, the mass memory device 1010 is 
a storage medium such as a hard disk which is generally slower than primary 
storage devices 1006, 1008. 
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The CPUs 1004 may also be coupled to one or more input/output 
devices 1012 that may include, but are not limited to, devices such as video 
monitors, track balls, mice, keyboards, microphones, touch-sensitive displays, 
transducer card readers, magnetic or paper tape readers, tablets, styluses, voice 
5 or handwriting recognizers, or other well-known input devices such as, of 
course, other computers. Finally, the CPUs 1004 optionally may be coupled 
to a computer or telecommunications network, e.g., an internet network or an 
intranet network, using a network connection as shown generally at 1014. 
With such a network connection, it is contemplated that the CPUs 1004 might 

10 receive information from the network, or might output information to the 

network in the course of performing the above-described method steps. Such 
information, which is often represented as a sequence of instructions to be 
executed using the CPUs 1004, maybe received from and outputted to the 
network, for example, in the form of a computer data signal embodied in a 

15 carrier wave. 

Although illustrative embodiments and applications of this invention 
are shown and described herein, many variations and modifications are 
possible which remain within the concept, scope, and spirit of the invention, 
and these variations would become clear to those of ordinary skill in the art 

20 after perusal of this appUcation. For instance, the present invention is 
described as being applicable to systems in which I/O fimctionality and 
therefore debugging ftinctionality is provided through the use of primitive 
ftmctions. However, primitive functions may be used to provide equivalent 
fimctionahty in a variety of systems and for a variety of purposes. Moreover, 
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the above-described process blocks are illustrative only. Therefore, it should 
be understood that primitive function requests and associated return 
information maybe simultaneously sent and received by multiple levels of the 
stack. Moreover, although the present invention is described as being 

5 implemented at system startup to create a parallel stack of primitive 

mechanisms, the stack of primitive mechanisms may be provided statically as 
well as created after system startup. Accordingly, the present embodiments 
are to be considered as illustrative and not restrictive, and the invention is not 
to be limited to the details given herein, but may be modified within the scope 

10 and equivalents of the appended claims. 
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Claims 

What is claimed is: 

1 . A method of providing replacement functions for a set of system 
5 services, comprising: 

requesting a primitive function from one of the set of system services, 
the primitive function rephcating the one of the set of system services with 
reduced functionality; and 

sending an identifier associated with the requested primitive function 
10 from the one of the set of system services. 

2. The method as recited in claim 1, wherein sending the identifier 
associated with the requested primitive function is performed only when the 
one of the set of system services performs a debugging function. 

15 

3 . The method as recited in claim 1 , wherein sending the identifier 
associated with the requested primitive function is performed only when the 
one of the set of system services performs at least one of an input and an 
output function. 

20 

4. A method of providing replacement functions for a stack of system 
services, the stack of system services including one or more layers, each layer 
representing one of the system services, wherein lower layers provide services 
to upper layers in the stack, the method comprising: 

25 sending a primitive function request down to one of the layers in the 

stack, the primitive function replicating the system service associated with the 
one of the layers in the stack; 

when the one of the layers is responsible for performing at least one of 
input and output, returning a primitive function identifier associated with the 

30 primitive function. 
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5. The method as recited in claim 4, further comprising: 

when the one of the layers is responsible for performing at least one of 
input and output, sending another primitive function request from the one of 
the layers in the stack to a lower layer in the stack. 

6. The method as recited in claim 4, further comprising: 

propagating the primitive function request down the one or more layers 
of the stack of system services. 



10 



7. A method of providing replacement functions for a stack of system 
services, the stack of system services including one or more layers, each layer 
representing one of the system services, wherein lower layers provide services 

15 to upper layers in the stack, the method comprising: 

sending a primitive function request down from a first one of the layers 
in the stack to a second one of the layers in the stack, the primitive function 
replicating the system service associated with the second one of the layers in 
the stack; 

20 returning primitive function information associated with the primitive 

function to the first one of the layers; and 

storing the primitive function information to enable the first one of the 
layers in the stack to communicate with the second one of the layers in the 
stack. 

25 

8. The method as recited in claim 7, wherein the primitive function 
information includes a pointer to the primitive function. 

9. The method as recited in claim 7, wherein the primitive function 
30 information includes state information data to be provided to the primitive 

function when the primitive function is called. 
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10. The method as recited in claim 7, further comprising: 

repeating the sending, returning, and storing steps over multiple layers 
of the stack such that a stack of primitive mechanisms parallel to the stack of 
system services is assembled. 

5 

1 1 . The method as recited in claim 7, wherein the returning and storing 
steps are performed when the second one of the layers in the stack contributes 
to at least one of input and output. 

10 

12. The method as recited in claim 7, wherein the returning and storing 
steps are performed when the second one of the layers in the stack contributes 
to debugging functions. 

15 

13. A system for providing replacement system functions, comprising: 
a set of components providing a set of services; 

a set of primitive functions associated with the set of services, the set 
of primitive functions replicating the set of services with reduced 
20 functionality; and 

a primitive function request mechanism adapted for returning one or 
more identifiers associated with one or more of the set of primitive functions. 

14. The system as recited in claim 13, further comprising: 

25 a primitive function calling mechanism adapted for calling one or more 

primitive functions associated with the one or more identifiers retumed by the 
primitive function request mechanism. 

15. The system as recited in claim 14, wherein the primitive function 
30 calling mechanism is associated with one or more of the set of components. 
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16. The system as recited in claim 13, wherein the one or more of the set 
of primitive functions replace one or more of the set of services when the set 
of services are determined to be inoperative. 

5 17. The system as recited in claim 1 3, wherein the one or more identifiers 
associated with one or more of the set of primitive functions are returned in 
response to a primitive function request. 

18. The system as recited in claim 13, further comprising: 

10 state information associated with each of the set of components, the 

state information including data that enables the corresponding service to 
communicate with another one of the set of services. 

19. The system as recited in claim 13, further comprising: 

1 5 state information associated with each of the set of components, the 

state information including data that enables the corresponding primitive 
function to identify another one of the set of primitive functions with which to 
communicate. 

20 

20. The system as recited in claim 13, wherein the set of services and the 
set of primitive functions provide input and output functionality. 

25 21 . The system as recited in claim 13, wherein the set of services and the 
set of primitive functions provide keyboard functionality. 
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22. A computer-readable medium for providing replacement functions for 
a set of system services, the computer-readable medium storing instructions 
thereon, comprising; 

instructions for requesting a primitive function from one of the set of 
system services, the primitive function replicating the one of the set of system 
services with reduced functionality; and 

instructions for sending an identifier associated with the requested 
primitive function from the one of the set of system services. 
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METHODS AND APPARATUS FOR MANAGING 
5 DEBUGGING I/O 



Abstract of the Disclosure 

Methods and apparatus for providing replacement functions for a set of 
10 system services include requesting a primitive function from one of the set of 
system services, the primitive function replicating the one of the set of system 
services with reduced functionality. A reference to the requested primitive 
function is then sent from the one of the set of system services. 
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